草庐IT

php - 在 switch 语句中重复代码

全部标签

ruby - 您如何使用 ptrace 对在 Rails 中运行的不受信任的代码进行沙盒处理?

假设我有这个糟糕的Controller代码:classMovesController一段时间以来,我一直在寻找一种最好的方法来沙箱化不受信任的代码的执行,并偶然发现了这个ruby​​-lang特性中的讨论:https://bugs.ruby-lang.org/issues/8468TherealsolutiontothisproblemistorunasandboxatthelevelaboveRuby.Irununtrustedcodeonhttp://eval.ininsideaptracebasedsandbox.CharlieSomerville对该主题的进一步研究并没有得到比

ruby - 你如何字符串化/序列化 Ruby 代码?

我希望能够在我的Ruby代码中编写一个lambda/Proc,将其序列化以便我可以将其写入磁盘,然后稍后执行lambda。有点像……x=40f=lambda{|y|x+y}save_for_later(f)稍后,在单独运行Ruby解释器时,我希望能够说...f=load_from_beforez=f.call(2)z.should==42Marshal.dump不适用于Procs。我知道Perl有Data::Dump::Streamer,而在Lisp中这是微不足道的。但是有没有办法在Ruby中做到这一点?换句话说,save_for_later的实现是什么??编辑:Myanswerbel

ruby-on-rails - 在 Web 服务器上执行用户提供的 ruby​​ 代码

我想让我的用户创建Ruby脚本,对驻留在Web服务器上的某些数据进行计算,然后输出结果。脚本在服务器上执行。有什么方法可以安全地做到这一点?更具体地说,我想:限制脚本可以使用的资源(内存和cpu),并限制其运行时间限制脚本可以使用哪些核心类(例如String、Fixnum、Float、Math等)让脚本访问和返回数据向用户输出任何错误是否有任何库或项目可以满足我的要求?如果不是Ruby,也许是其他语言? 最佳答案 您可以使用“空白板”作为干净的房间,并使用沙箱来设置safelevel到4。一张白纸,一个你已经从中剥离了所有方法的对象

ruby - Rails3/ruby gem 中是否有将状态代码映射到消息的方法?

比如200=>Found403=>Notauthorized404=>Notfound我猜Rails3已经具有此功能,因为您可以将散列传递给render:status=>:not_found,我只是找不到以其他方式执行此操作的方法。如果没有,有人知道可以做到这一点的gem吗? 最佳答案 irb(main):001:0>Rack::Utils::HTTP_STATUS_CODES[200]=>"OK"irb(main):002:0>Rack::Utils::HTTP_STATUS_CODES[403]=>"Forbidden"irb(

ruby - 为什么我可以引用从未运行过的 if/unless/case 语句之外的变量?

为什么下面的代码不会报错?iffalsex=0endx#=>nil而以下确实会引发错误:y#NameError:undefinedlocalvariableormethod`y'formain:Objectunless和case语句也会发生同样的事情。 最佳答案 这是因为Ruby解析器的工作方式。变量由解析器定义,解析器逐行遍历代码,而不管它是否会实际执行。一旦解析器看到x=,它就会在当前范围内定义局部变量x(值为nil)。因为if/unless/case/for/while不创建新的作用域,x被定义并且在代码块之外可用。由于条件为

ruby-on-rails - Ruby On Rails 应用程序中的重复任务 : Cron or other?

我目前正在编写一个从RSS源中提取新信息的应用程序,并且必须以一定的频率更新这些RSS源。目前我只在用户请求提要时拉取,但我想将该行为更改为自动定期获取。我正在编写一个与数据库交互并通过cron定期启动的shellscript-但这是很多双重努力,所以我想知道执行此操作的“RailsWay”或“RubyWay”是什么。我正在使用Ubuntu、Apache和Passenger。您能否建议甚至可能包含在应用程序中的更好的方法,这样我就可以轻松地将应用程序部署到另一台机器上,而不必与cron混在一起? 最佳答案 我建议做一些类似rake任

ruby-on-rails - "use"Ruby/Rails/Rack 代码中的关键字/词

最近我在查看与goliath相关的一些代码时,偶然在Ruby代码中看到了这个词use。,中间件等。看起来它不同于include/extend,andrequire.有人可以解释为什么存在这个use关键字,以及它与include/require有何不同?它是如何工作的,何时使用它? 最佳答案 文档正如人们指出的那样,use不是Ruby关键字,它实际上是Rack::Builderclass的一个方法。:use(middleware,*args,&block)Specifiesmiddlewaretouseinastack.Thisdoc

ruby - 如何在不重复缩进代码的情况下在 HAML 中执行 if/else

根据用户是否登录,我想打印不同类型的%body-tag。我目前是这样做的:-ifdefined?@user%body(data-account="#{@user.account}")%h1Welcome-#allmycontent-else%body%h1Welcome-#allmycontent如您所见,其中有很多重复代码。我怎样才能消除这个?我已经尝试过以下方法:-ifdefined?@user%body(data-account="#{@user.account}")-else%body%h1Welcome-#allmycontent不幸的是,这不起作用,因为HAML将其解释为好

ruby - Ruby 中有 goto 语句吗?

有没有办法从指定行开始,比如goto语句? 最佳答案 首先,它是声明,而不是命令。二、看ruby-goto.三、注意事项Category:Library/Evil 关于ruby-Ruby中有goto语句吗?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/1634913/

ruby - 需要方法内的语句?

我正在为测试套件开发API。API中的一种方法需要使用API中其他任何地方都不需要的库。我的问题是使用库的require语句应该放在方法内还是每次加载API时。该库不是很大,因此不会对性能产生重大影响。 最佳答案 如果依赖项具有良好的命名空间组织(不会污染全局命名空间)并且不大(不会减慢启动时间),我会说将其放在文件的顶部。这是人们期望找到require语句的地方。如果它有其中任何一个问题,请考虑将其放在尽可能有限的范围内。 关于ruby-需要方法内的语句?,我们在StackOverfl